package com.kamistoat.meimeistore.ware.dao;

import com.kamistoat.meimeistore.ware.entity.WareSkuEntity;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

import java.util.List;

/**
 * 商品库存
 * 
 * @author kamistoat
 * @email linjianshanke@163.com
 * @date 2021-09-12 16:45:28
 */
@Mapper
public interface WareSkuDao extends BaseMapper<WareSkuEntity> {

    // 查询当前sku在那几个仓库都有货
    List<Long> listWareHasSkuStock(@Param("skuId") Long skuId);

    // 更新SQL，锁定库存。成功返回操作1行，不成功返回操作0行
    Long lockSkuStock(@Param("skuId") Long skuId, @Param("wareId") Long wareId, @Param("num") Integer num);

    // 解锁库存
    void stockLockedRelease(@Param("skuId") Long skuId, @Param("wareId") Long wareId, @Param("skuNum") Integer skuNum);

    /**
     * 原子扣减被锁定的库存
     * @param skuId 商品id
     * @param skuNum 商品库存
     * @param wareId 仓库编号
     */
    void successPayAndDeductStock(@Param("skuId") Long skuId, @Param("skuNum") Integer skuNum, @Param("wareId") Long wareId);
}
